$(function () {
    var url = location.search //获取url中"?"符后的字串 ('?modFlag=business&role=1')
    var theRequest = new Object()
    if (url.indexOf('?') != -1) {
        var str = url.substr(1) //substr()方法返回从参数值开始到结束的字符串；
        var strs = str.split('&')
        for (var i = 0; i < strs.length; i++) {
            theRequest[strs[i].split('=')[0]] = strs[i].split('=')[1]
        }
    }
    if (theRequest.btn == 'editArticle') {
        // 发起 ajax 请求获取数据
        $.ajax({
            type: "GET",
            url: "/my/article/" + theRequest.id,
            success: function (res) {
                layui.layer.msg(res.message);
                // 如果删除成功  
                if (res.status == 0) {
                    // 给表单赋值
                    // layui.form.val("form-pub", res.data[0]);
                    $('#form-pub [name=title]').val(res.data[0].title);
                    $('#form-pub [name=cate_id]').val(res.data[0].cate_id).text(res.data[0].cate_id);
                    $('#form-pub [name=content]').val(res.data[0].content);
                    $('#form-pub [name=cover_img]').val(res.data[0].cover_img);
                    // 渲染封面
                    if (res.data[0].cover_img) {
                        $image
                            .cropper('destroy')      // 销毁旧的裁剪区域
                            .attr('src', res.data[0].cover_img)  // 重新设置图片路径
                            .cropper(options)        // 重新初始化裁剪区域
                    }
                }
            }
        });
    }

    /**** 获取文章分类列表 ****/
    getArticleCateList();

    /*** 初始化富文本编辑器 ***/
    initEditor();

    /****** 图片封面裁剪 ******/
    // 1. 初始化图片裁剪器
    var $image = $('#image')

    // 2. 裁剪选项
    var options = {
        aspectRatio: 400 / 280,
        preview: '.img-preview'
    }

    // 3. 初始化裁剪区域
    $image.cropper(options)

    /********* 选择封面 *********/
    // 点击 上传 按钮后模拟点击隐藏的上传文件按钮
    $('#btnChooseImage').on('click', function () {
        $('#file').click();
    });

    /********* 图片更换 *********/
    $('#file').on('change', function (e) {
        // 获取用户选择的文件
        var filelist = e.target.files;
        // 判断用户是否选择了文件
        if (filelist.length == 0) {
            return layui.layer.msg('请选择照片！');
        }

        // 更换裁剪的图片
        // 1.拿到用户选择的文件
        var file = filelist[0];
        // 2.根据选择的文件，创建一个对应的 URL 地址：
        var newImgURL = URL.createObjectURL(file);
        // 3.先`销毁`旧的裁剪区域，再`重新设置图片路径`，之后再`创建新的裁剪区域`：
        $image
            .cropper('destroy')      // 销毁旧的裁剪区域
            .attr('src', newImgURL)  // 重新设置图片路径
            .cropper(options)        // 重新初始化裁剪区域

    });


    // 定义文章发布状态的变量
    var art_state = '已发布';
    // 为存为草稿按钮 绑定点击事件
    $('#btnSaveDraft').on('click', function () {
        art_state = '草稿';
    });

    // 为表单绑定 submit 提交事件
    $('#form-pub').on('submit', function (e) {
        // 1.阻止表单的默认提交行为
        e.preventDefault();
        // 2.基于 form 表单 快速创建一个 FormData 对象
        var fd = new FormData($(this)[0]);
        // 3.将文章的发布状态存储到 fd
        fd.append('state', art_state);
        // 4.将裁剪后的图片，输出为文件
        $image
            .cropper('getCroppedCanvas', {
                // 创建一个 Canvas 画布
                width: 400,
                height: 280
            })
            .toBlob(function (blob) {
                // 将 Canvas 画布上的内容，转化为文件对象
                // 得到文件对象后，进行后续的操作
                // 5.将封面文件存储到 fd 中
                fd.append('cover_img', blob);
                // 6.发布文章
                publishArticle(fd);
                fd.forEach(function (v, k) {
                    console.log(v, k);
                })
            });
    });

    /****** 函数定义区域 ******/
    // 获取文章分类列表
    function getArticleCateList() {
        $.ajax({
            type: "GET",
            url: "/my/artcate/cates",
            success: function (res) {
                // layui.layer.msg(res.message);
                // 如果获取成功  
                if (res.status == 0) {
                    // 第一个参数传入 id 不需要加 #
                    var htmlStr = template('tpl-cates', res);
                    $('[name=cate_id]').html(htmlStr);
                    layui.form.render();
                }
            }
        });
    };
    // 发布文章的方法
    function publishArticle(fd) {
        // 发起 Ajax 请求
        $.ajax({
            type: "POST",
            url: "/my/article/add",
            data: fd,
            // 如果向服务器提交的是 FormData 格式的数据
            // 必须添加以下两个配置项
            contentType: false,
            processData: false,
            success: function (res) {
                layui.layer.msg(res.message);
                // 如果添加成功  
                if (res.status == 0) {
                    // 跳转到文章列表页面
                    location.href = '/article/art_list.html';
                }
            }
        });
    };
});